-
Notifications
You must be signed in to change notification settings - Fork 15k
[AArch64] Remove post-decoding instruction mutations #156364
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[AArch64] Remove post-decoding instruction mutations #156364
Conversation
✅ With the latest revision this PR passed the C/C++ code formatter. |
769d57a
to
ed29165
Compare
5cc7d7a
to
261f86f
Compare
a112090
to
c66fd0b
Compare
261f86f
to
d72f713
Compare
b60b806
to
ec3ee1e
Compare
772f655
to
7112890
Compare
ec3ee1e
to
098f887
Compare
7112890
to
ed950c3
Compare
098f887
to
46fc93b
Compare
ed950c3
to
f3b4f27
Compare
ee67c36
to
9709854
Compare
f3b4f27
to
6830ba2
Compare
9709854
to
aa97c88
Compare
6830ba2
to
b95e187
Compare
aa97c88
to
f31a7b8
Compare
b95e187
to
9758552
Compare
607d600
to
054fefc
Compare
gentle ping |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not the biggest expert here, and bits<0> seems a little unusual, but as far as I can tell this LGTM. Thanks
It kind of makes sense if you look at related instructions, e.g.:
|
These instructions can now be fully decoded automatically.
5e59a9a
to
cbbc47b
Compare
This was updated in #156364 but `-ignore-non-decodable-operands` was removed from the wrong tablegen arg list (arm vs aarch64)
LLVM Buildbot has detected a new failure on builder Full details are available at: https://lab.llvm.org/buildbot/#/builders/18/builds/21322 Here is the relevant piece of the build log for the reference
|
LLVM Buildbot has detected a new failure on builder Full details are available at: https://lab.llvm.org/buildbot/#/builders/168/builds/16243 Here is the relevant piece of the build log for the reference
|
LLVM Buildbot has detected a new failure on builder Full details are available at: https://lab.llvm.org/buildbot/#/builders/72/builds/15142 Here is the relevant piece of the build log for the reference
|
Add
bits<0>
fields to instructions using the ZTR/MPR/MPR8 register classes.These register classes contain only one register, and it is not encoded in the instruction.
This way, the generated decoder can completely decode instructions without having to perform a post-decoding pass to insert missing operands.
Some immediate operands are also not encoded and have only one possible value "zero". Use this trick for them, too.
Finally, remove
-ignore-non-decodable-operands
option fromllvm-tblgen
invocation to ensure that non-decodable operands do not appear in the future.